<template>
	<view>
		<view class="smart-panel-head">
			<view class="smart-panel-head-title ">form</view>
		</view>
		<form @submit="formSubmit" @reset="formReset">
			<view class="uni-form-item uni-column">
				<view class="title">姓名</view>
				<input class="uni-input" name="nickname" placeholder="请输入姓名" />
			</view>

			<view class="uni-form-item uni-column">
				<view class="title">性别</view>
				<radio-group name="gender">
					<label class="uni-label">
						<radio value="male" />男
					</label>
					<label class="uni-label">
						<radio value="female" />女
					</label>
				</radio-group>
			</view>

			<view class="uni-form-item uni-column">
				<view class="title">爱好</view>
				<checkbox-group name="loves">
					<label class="uni-label">
						<checkbox value="reading" />读书
					</label>
					<label class="uni-label">
						<checkbox value="writing" />听歌
					</label>
					<label class="uni-label">
						<checkbox value="sports" />运动
					</label>
				</checkbox-group>
			</view>
			<view class="uni-form-item uni-column">
				<view class="title">年龄</view>
				<slider value="20" name="age" show-value></slider>
			</view>
			<view class="uni-form-item uni-column">
				<view class="title">保留选项</view>
				<view>
					<switch name="keepOption" />
				</view>
			</view>
			<view class="uni-btn-v">
				<button form-type="submit">Submit</button>
				<button type="default" form-type="reset">Reset</button>
			</view>
		</form>
	</view>
</template>
<script>
import graceChecker from "@/common/graceChecker.js"; 
export default {
  data() {
    return {

    }
  },
  methods: {
    formSubmit: function (e) {
      console.log('form发生了submit事件，携带数据为：' + JSON.stringify(e.detail.value))
      var rule=[
        {name:"nickname",checkType : "string",checkRule:"1,3",errorMsg:"姓名应为1-3个字"},
        {name:"gender",checkType : "in",checkRule:"male,female",errorMsg:"请选择性别"}, 
        {name:"loves",checkType : "notnull",checkRule:"",errorMsg:"请选择爱好"}
      ];
      var formData=e.detail.value;
      var checkRes=graceChecker.check(formData,rule);
      if(checkRes){
        uni.showToast({
          title:"验证通过!",icon:"none"
        });
      }else{
        uni.showToast({
          title:graceChecker.error,icon:"none"
        });
      }
      uni.showModal({
        content:'表单数据内容：'+JSON.stringify(e.detail.value),
        showCancel:false
      });
    },
    formReset:function (e){
      console.log('清空数据')
    }
  }
}
</script>